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(54) Multiuser detection in CDMA using a correlation matrix 



(57) A radio communications receiver which oper- 
ates to detect radio signals and to recover data repre- 
sentative of the radio signals in the presence of contem- 
poraneously detected interfering signals, the radio com- 
munications receiver comprising means to detect the ra- 
dio signals (6, 8) and to generate digital base band sig- 
nals representative of the radio signals, means to form 
a correlation matrix (12) from the base band signals, a 
data processor (16) which operates to generate a factor 



(fl) of the correlation matrix (S), and to recover the data 
from the factor, wherein the data processor (16) oper- 
ates to generate the factor (fl) by calculating first ele- 
ments of the factor (fl) from the correlation matrix (S) 
using a factorisation algorithm, in accordance with a pre- 
determined structure of the factor (fl), and forming sec- 
ond elements of the matrix (fl) by selectively copying 
first elements in accordance with the pre-determined 
structure. 
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Description 

[0001] The present invention relates to radio communications receivers and in particular to radio communications 
receivers which operate to detect radio signals and to recover data representative of the radio signals in the presence 
5 of interfering signals. The present invention also relates to methods of receiving radio signals and recovering data 
representative of the radio signals in the presence of interfering signals. 

[0002] In data and signal processing applications, there is often a requirement to factorise a matrix of signal samples 
to the effect of providing a factor matrix having particular characteristics. For example, the desired matrix factor may 
be upper triangular or lower triangular in that the lower or upper part of the matrix may be filled with zeros. As a result, 
10 the factorised matrix may be interpreted as a set of simultaneous equations and these equations solved in a manner 
facilitated by the upper or lower triangular form. 

[0003] An example where such matrix factorisation is required is in radio communications receivers, and in particular 
radio communications receivers which are arranged to detect radio signals and generate data from these radio signals 
in the presence of contemporaneously detected interfering signals. Such is the case with radio systems arranged to 

is operate with code division multiple access. Code division multiple access is a radio communications technique in which 
data to be communicated is combined with a spreading code in some way before being modulated onto a radio fre- 
quency carrier signal. At the receiver the radio signals are detected and the data is recovered by de-spreading the 
radio signals with knowledge of the spreading code used at the transmitter to form the radio signals. As a result of the 
spreading of the data, the receiver is able to generate a gain in the power of the detected signal with respect to noise 

20 and other signals for the wanted signal. As such, signals from a plurality of transmitters may be contemporaneously 
transmitted using different spreading codes and separated at corresponding receivers to the effect that the data which 
the radio signals represent may be recovered in spite of the presence of the interfering signals from the other trans- 
mitters. However in order to detect the data from a wanted radio signal, the receiver is required to reject the unwanted 
signals which are contemporaneously detected with the wanted signal. As such, the receivers require extensive signal 

25 processing capabilities in order to effect the task of detecting the data in the presence of the unwanted signals. This 
represents a task of some considerable complexity. As such, it may not be possible to detect the data in real time, 
because state of the art signal processors are not able to execute the number of calculations required for the signal 
processing algorithms before the data must be presented at an output. However, it is not always necessary to solve 
signal processing problems exactly. It is known to be possible to only compute an approximation to the exact solution 

30 without degrading the overall performance of the system. Computing an approximation to the solution reduces the 
amount of time spent solving the problem, reduces the amount of hardware required for implementing the algorithm, 
reduces the power consumption of the device and in some cases makes it possible to achieve real-time behaviour in 
the first place. 

[0004] A part of a process most appropriate for detecting data communicated in accordance with a code division 
35 multiple access system requires the factorisation or decomposition of a correlation matrix. In order to effect real-time 
operation with known signal processors, it is necessary to provide an approximation to an exact solution of a factori- 
sation of this correlation matrix. In an article entitled "Real-time feasibility of joint detection CDMA" by J. Mayer, J. 
Schlee and T. Weber, published in the proceedings of the second European Personal Mobile Communications Con- 
ference, Bonn, Germany, September 1997, pages 245 to 252, an approximation of a matrix factorisation is described 
40 using a known numerical approximation process. However, the computational effort needed to perform this multi-user 
detection is still considerable. 

[0005] A technical problem therefore exists in further reducing the computational complexity, or correspondingly 
increasing the accuracy which can be achieved using an approximation method to generate factor of a matrix. 
[0006] The technical problem is addressed generally by considering the generation of the matrix factor by analysing 
45 the structure matrix factor and determining from the structure which of the elements of the matrix must be calculated 
exactly using a factorisation algorithm, and which of the elements may be copied from the components calculated 
exactly. 

[0007] According to the present invention there is provided a receiver which operate to detect radio signals and to 
recover data representative of the radio signals in the presence of interfering signals, said radio communications re- 

50 ceiver comprising means to detect said radio signals and to generate digital base-band signals representative of the 
radio signals, means to form a correlation matrix from the base-band signals, and a data processor which operates to 
generate a factor of the correlation matrix and to recover the data from the factor, wherein the data processor operates 
to generate the factor by calculating first elements of the factor from the correlation matrix using a factorisation algorithm 
in accordance with a pre-determined structure of the factor matrix and forming second elements of the matrix by se- 

55 lectively copying said first elements from a first row in accordance with the pre-determined structure. 

[0008] The pre-determined structure of the factor matrix may be determined in accordance with a band structure 

from the form of the calculation and the technique used to represent the data as radio signals. 

[0009] The first and second elements may be rows or columns of the matrix. The term rows as used herein may be 
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substituted for the term column in that by inverting either the correlation matrix or the factor matrix or both, the columns 
become rows and the rows become columns. The factor may be and upper triangular matrix or a lower triangular matrix. 
The radio signals and the interfering signals may be generated in accordance with code division multiple access. The 
code division multiple access may be time division-code division multiple access. 

5 [0010] The known approximation methods for factoring a correlation matrix as disclosed in the above mentioned 
reference entitled, 'Real-time feasibility of joint detection CDMA", by Mayer, Schlee, Weber, have been guided by a 
mathematical view of the calculation and the treatment has been restricted to one specific algorithm for computing this 
part, namely the Cholesky algorithm. The present invention, however results from an algorithmic analysis of the matrix 
factorisation, from which a significant reduction in complexity is facilitated. 

10 [001 1] For the particular example of signal processing in a CDMA receiver, an approximation method greatly increas- 
es the capability of the receiver to cope with a technical problem known to those skilled in the art as the near/far 
problem, where different users are received with very different signal powers. As contemporaneously received unwant- 
ed signals with comparatively high signal powers tend to prevent the detection of wanted radio signals having a com- 
paratively low signal power. 

is [0012] According to an aspect of the present invention there is provided a method of detecting a radio signal and 
recovering data representative of said radio signal in the presence of interfering signals, said method comprising the 
steps of; 

detecting said radio signals and generating digital base band signals representative of said radio signals, 
20 - generating a correlation matrix (S) from said base band signals, 

- generating a matrix factor (R) of said correlation matrix, and 

- recovering said data from said factor (R), wherein said factor (R) is generated in accordance with the following 
operations; 

- calculating first elements of the factor (R) from the correlation matrix (S) using a factorisation algorithm, in accord- 
2$ ance with a pre-determined structure of the factor (R) ; and 

- forming second elements of the matrix (R) by selectively copying elements from said first rows in accordance with 
said pre-determined structure. 

[0013] . According to a further aspect of the present invention, there is provided a method of generating at least one 
30 factor (R) of a matrix (S) t said factor (R) being upper or lower triangular in form, said method comprising the steps of; 

- calculating first elements of the factor (R) from the matrix (S) using a factorisation algorithm, in accordance with 
a pre-determined structure; and 

forming second elements of the matrix (R) by selectively copying elements from said first elements in accordance 
35 with said pre-determined structure. 

[001 4] One embodiment of the present invention will now be described by way of example only with reference to the 
accompanying drawings wherein; 

40 FIGURE 1 is a schematic block diagram of a mobile radio telecommunications system; 

FIGURE 2 is a schematic block diagram of a receiver which operates within the mobile radio communication system 
shown in Figure 1 ; 



45 FIGURE 3 is an Illustrative representation of a known method of generating an approximation of a factor matrix R, 
from a correlation matrix S; 



so 



FIGURE 4 is a representation of a process of generating a factor matrix R, from a correlation matrix S according to 
the present Invention; and 

FIGURE 5 is a further illustration of a process generating a factor matrix of a correlation matrix S according to the 
present invention. 



[0015] One embodiment of the present invention will now be described with reference to a mobile radio communi- 
55 cations system which operates in accordance with code division multiple access. The present invention may operate 
with time division-code division multiple access (TD-CDMA) or wide band code division multiple access (W-CDMA). 
Both multiple access techniques will benefit from exploiting opportunities for approximation. The TD-CDMA system is 
required to perform joint detection of all users that are active In one time/frequency slot. Compared to a TD-CDMA 
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system, the number of simultaneously active users in a W-CDMA system is much higher. Therefore, it is currently not 
possible to jointly detect all users. However, it is possible to perform multi-user detection, where only a subset of all 
users is included in the joint detection problem and the rest is treated as interference. Approximation methods increase 
the number of users that can be included in one detection step and can thus increase the resistance of the system to 

s the near/far effect. This in turn leads to reduced demands on the power control. 

[0016] The illustrative embodiment if the present invention will be described with reference to a TD-CDMA system. 
An example of part of a mobile radio telephone system which operates in accordance with a TD-CDMA system is 
illustrated in Figure 1. In Figure 1, three base stations BS are shown to be interconnected via a mobile network infra- 
structure, NET. Data is communicated between mobile stations MS and the base stations BS, by transmitting and 

10 receiving radio signals 1, between the base and mobile stations operating within a radio coverage area effected by 
each of the base stations BS. The radio coverage area is shown illustrated as a broken line 2, and serves to indicate 
a boundary within which radio communications can be effected with the mobile stations MS. In the present illustrative 
embodiment the mobile stations MS communicate with the base stations BS in accordance with a TD-CDMA system. 
A more detailed explanation of how data is communicated using a time division CDMA system is provided in an article, 

is entitled , .Performance of a Cellular Hybrid C-TDMA Mobile Radio System Applying Joint Detection and Coherent Re- 
ceiver Antenna Diversity" by G. Blanz, A. Klein, M. NaBhan and A. Steil published in the IEEE Journal on Selected 
Areas in Communications, Volume 12, no. 4, May 1994 at page 568, the content of which is incorporated herein by 
reference. However for the present explanation it should be noted that communications using TD-CDMA systems is 
characterised in that radio frequency carrier signals via which communication of data is effected are divided into a 

20 plurality of time-slots. Each of these time-slots is assigned to a plurality of mobile stations which operate to communicate 
radio signals in the time-slot. In order to separate data communicated by the plurality of mobiles assigned to the same 
time-slot, each mobile is provided with a user specific code which is convolved with the data to be communicated. A 
receiver of the radio signals operates to separate data communicated by other mobile stations MS contemporaneously, 
in accordance with the user specific code. As will be appreciated, a similar arrangement is effected for data commu- 

25 nicated from the base stations to the mobile stations. 

[0017] A receiver which operates within the mobile radio communications system shown in Figure 1 , is illustrated in 
Figure 2. In Figure 2 a wanted radio signal transmitted from a mobile station is represented by the line 1, whereas 
unwanted signals transmitted by other mobile stations are represented by the lines 4. The wanted and unwanted radio 
signals are detected by an antenna 6 and fed to a radio frequency down converter means 8 of the receiver 10. The 

30 radio frequency down converter means 8 operates to convert the received radio signals into a base band representation 
which are thereafter analogue to digital converted and fed to a first data processor 1 2. The first processor 1 2 operates 
to generate a correlation matrix S, of the received radio signals in combination with a plurality of CDMA-spreading 
codes fed from a data store 14. The plurality of spreading codes held in data store 14 correspond to each of the 
spreading codes used to spread the data modulated onto the wanted and unwanted radio signals. The data store 14 

35 may also include a set of training sequences which are embedded in the unwanted and wanted signals from which a 
channel impulse response of the communications channel through which the wanted and unwanted radio signals have 
passed may be estimated. The correlation matrix S t is thereafter passed to a further data processor 1 6 which operates 
to generate a factorised matrix R from the correlation matrix Sfrom which data representative dof the wanted radio 
signals is generated an output on a conductor 1 8. Operation of the data processor will now be described in more detail. 

40 [001 8] The present example embodiment will be illustrated with regard to a receiver 1 0, which operates in accordance 
with TD-CDMA. As with W-CDMA, the problem can be reduced to solving a system of linear equations, after the 
correlation matrix Shas been generated by the receiver. A received radio signal which has been generated in accord- 
ance with a TD-CDMA system can be modelled with an over-determined linear equation system, as illustrated in equa- 
tion (1): 

46 

Ad=e (1) 

[0019] The system matrix A contains the combined channel impulse responses and spreading codes of each of the 
50 signals contemporaneously received in each time slot. The vector e contains the received antenna samples and the 
vector d denotes the unknown data symbols. This system of equations is solved according to a least squares criterion. 
This may be effected, by factoring a correlation matrix, formed from the matrix A, by multiplying the matrix with a 
Hermrttian transpose of itself. This is illustrated by equation (2): 



55 



A H Ad=A H e 
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[0020] The data is recovered from equation (2), by forming a factor matrix ft as determined by equation (3): 

A H A = tf*R (3) 
[0021] Where in equation (3), f? is upper triangular. From equations (2) and (3), equation (4) may be formed: 

pt i Rd = A H e (4) 

[0022] Equation (4) can be trivially solved by two substitution operations to recover the data vector d. To facilitate 
the following explanation, the correlation matrix to be factored is designated S, where S = R H R. 
[0023] A key step in this process of recovering the data vector d, is generating the factor matrix ft This can be 
generated exactly using an algorithm known to those skilled in the art as the Cholesky algorithm, a description of which 
may be found in a publication entitled 'Coding, Modulation and Multiuser Decoding for DS-CDMA Systems', PhD thesis 
by T Ottosson, Chalmers University of Technology, Goteborg, Sweden, 1 997. Having regard to the number of elements 
present in the matrix S, which is determined by the number of data symbols in the vector d, in combination with the 
length of the spreading sequence and the delay spread of the channel impulse response, the elements of the factor 
matrix flcan not be calculated exactly using the Cholesky algorithm, as this would either prevent real-time operation, 
or require a data processor with a processing power not current available within the state of the art. However the matrix 
S is known to have a structure which is Hermitian, positive definite and is also a block Toeplitz matrix with a band 
structure. As such a known method for generating an approximation to the factor matrix R t is disclosed in the above 
referenced publication entitled "Realtime feasibility of joint detection CDMA" by Mayer, Schlee and Weber. This ap- 
proximation will now be described with reference to Figure 3. 

[0024] Figure 3 provides an illustrative representation of an approximation to the matrices Sand ft For the correlation 
matrix S, and the matrix factor ft the following conventions are adopted: 

S = (s i p i S = A H A 

R = (r$, with R upper-triangular and R H R = S , and for both S and ft 7 £ / £ n , 1£j£n. 

[0025] Let the blocks of S and R be of size kxk. Then the block-Toeplitz structure of S and the approximate block- 
Toeplitz structure of R can be described as expressed in equation (5): 

s U = s t-k>Hc an6r lJ* r l*J* (5) 

[0026] Let J be a square sub-matrix from the upper left corner of S, which is shown in Figure 3, bounded by a dashed 
line 20. These elements of the matrix S, are bounded by an index /?, as shown in Figure 3, and described mathematically 
by equation (6): 

S=(sjj), \£iZn<n, U)Sw<w (6) 



[0027] The Cholesky factor R of S is then a sub-matrix from the upper left comer of R bounded by a dashed line 22, 
as expressed by equation (7): 



R = {ry), lzizn<n, \zj£fl<n (7) 



55 



[0028] The exact matrix R can thus be approximated by computing the Cholesky factor from a smaller sub-matrix 
S of Sand then filling the rest of R with copies of elements of R , as indicated by (5). As shown with the dashed line 
20, 22, in Figure 3, S and R are placed at the upper left corner of S and ft respectively. After computing R , shown 
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as darker blocks on the right hand side of Figure 3, the remaining blocks of R, which are shown in a lighter shade, are 
copied from corresponding columns of the sub-matrix R , in accordance with a pre-determined mathematical structure. 
[0029] As described in the above referenced publication "Real-time feasibility of joint detection CDMA', by Mayer, 
Schlee and Weber, the actual computation of R can be done with the Cholesky algorithm, which requires one square- 

s root operation and one division for each computed row of R . Let vbe the degree of the block-band structure of R, that 
is, that there are only vkX k non-zero blocks directly on the diagonal and to the right of R in each block-row. To capture 
all the information of R, one needs to choose an R that has at least a size of v X v blocks, as indicated in Figure 3. 
This results in kv square root operations and kv divisions as required by the Cholesky algorithm. 
[0030] This known technique for reducing a number of calculations required to generate the factor matrix R, is base 

10 on a mathematical assessment of the process for generating the matrix factor. However, the Applicant has observed 
that by analysing further the structure of the factor matrix R, it is possible to achieve further reductions in a number of 
calculations required to produce the factor matrix R. In this way, the approximate block-Toeplitz structure of R is ex- 
ploited, to the effect that only a small part of R is computed, and then the remaining parts filled with suitable copies of 
the computed part. Exploiting this opportunity to reduce the number of calculations is an important part of being able 

is to perform the joint-detection in real-time. The algorithms that can be used to compute R can be written in a form so 
that the elements of R are produced row-wise from top to bottom and within each row from left to right. While executing 
the algorithm, it is possible to leave out the computation of more of the elements r f j, which are substituted with copies 
from those elements calculated exactly using the factoring algorithm, according to a pre-determined approximation for 
the structure of R . This approach leads to a close intertwining of the actual execution of the algorithm and the approx- 

20 imation process and thus results in great flexibility for controlling the approximation process. 

[0031] This general principle can be applied to all algorithms that compute elements of a factor matrix R, using known 
factoring algorithms such as the Cholesky algorithm or other known algorithms such as the Block-Schur algorithm, 
which is known to those skilled in the art. Furthermore, it is beneficial for a wide range of signal processing tasks, like 
joint-detection in TD-CDMA systems and multi-user detection in W-CDMA systems. 

25 [0032] The pre-determined structure, from which those elements of R, which need to be calculated using the factoring 
algorithm, and those elements which may be copied, can be substantially arbitrary and can vary dynamically in ac- 
cordance with, for example, the prevailing conditions for data communications using a CDMA radio communications 
system. 

[0033] There are many forms which the pre-determined structure may take. By carefully choosing one, it is possible 
30 to only compute the most "important" elements. Copying an element according to (5) makes only really sense when 
the copied-from element exists. This means that at least the first k rows of R should be computed, because there are 
no elements from which they could be copied from. As a result of the pre-determined structure, which may, as in 
accordance with the present embodiment, identify a band-structure of the correlation matrix S, only the first vk elements 
of each of /crows are non-zero. In mathematical terms, this can be expressed as shown in equation (8): 

3$ 

shall we compute r„? ej s / s /rand jzvk? (8) 



[0034] Figure 4 provides an illustration of how the pre-determined structure of R, is used to determine which elements 

40 can be copied and which must be calculated using the factoring algorithm. As illustrated, the darker shaded blocks 24, 
of R, on the right hand side of Figure 4 are computed and the lighter blocks 26, are copied from them. Starting from 
this rule, the region of the computed elements can easily be enlarged. This generalisation has been achieved by 
examining the process of computing the Cholesky factor from an algorithmic point of view. The state of the art teaches 
the skilled person only a mathematical, high level analysis of the calculation of the matrix factor R. This mathematical 

45 view only provided knowledge of matrix-level computations. Analysing an implementation of the calculation, provides 
an insight into the structure of the factor matrix, from which a reduction in the number of computations can be effected. 
As will be clear to those skilled in the art, the illustrative embodiment of the present invention which finds an approxi- 
mation to the generation of a Cholesky factor R, is one example of a general approach in which analysis of the structure 
of the factor matrix reveals a way in which a reduction in a number of computations can be achieved in calculating an 

60 approximation to a matrix factor. 

[0035] Simulations have shown that exploiting these new opportunities for saving computational effort lead to an 
improvement over the existing solutions. These simulations have been carried out with a TD-CDMA model and have 
shown that the approximation to R according to the embodiment of the present invention, produces no reduction in the 
bit error rate of the recovered data, with a reduced amount of calculations. Only the first v blocks of the first block-row 

55 need to be computed, the rest of R can be copied from them. Compared to the known method of computing R, the 
embodiment reduces the amount of square root operations and divisions from vkXo k. For typical channel models, this 
represents a reduction in the amount of calculations by around one third. 
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[0036] The new approach is applicable to a wide range of algorithms, such as the original Cholesky algorithm or the 
improved Block-Schur algorithm. It can be used in many signal processing tasks that require a matrix decomposition 
to reduce time and space complexity. For example, it can be used in the joint-detection process in a TD-CDMA system 
and for mufti-user detection in W-CDMA systems. It not only provides a finer control over the amount and specific 
placement of elements which are calculated exactly, it also provides a means for interleaving computation and approx- 
imation. This enables the matrix factor calculation to be performed by doing a little computation, then a little bit of 
copying and then resuming the computation. This facilitates use of the general approximation approach for matrices 
with a different kind of structure. For example, when considering the problem of incorporating decision feedback into 
the joint detection process, the matrix S has a Toeplitz-block structure instead of block-Toeplitz structure. It is then 
beneficial to periodically alternate between computing and copying. There is no easy way to express this with matrix 
notation alone. Figure 5 provides an illustration of a different form of a Toeplitz-block structure with internal band struc- 
ture and the layout of the elements of R according to whether they should be computed (dark) or copied (light). 
[0037] As a further illustration of the example embodiment of the invention, a particular example of a calculation of 
a matrix factor R is provided in the following paragraphs, in comparison to a calculation using the Cholesky factoring 
algorithm. 

[0038] The Cholesky algorithm for computing R can be expressed as follows: 



for i in 1 to « 

for j in i to n 
compute ry 



compute ry 




for k in 1 



to i -1 



x = x 



-Wig 



if 



J = i 



else 



ry=xlr U 



[0039] Note that the division in the case where /* yean be replaced by a multiplication by pre-computing 1//#once 
per row. The interleaving of actual computations and copy operations can then be achieved like this: 
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10 



is 



20 



for I in 1 to n 

for j in i to n 

if we should compute r\j 

compute ry 

else 

copy ry 

copy ry 

if i > k and y > A 

r ij = 

else 

r/,- = 0 

[0040] A numerical example of a correlation matrix S is provided as follows: 



25 



5 = 



4 2 0 
2 4 2 
0 2 4 



30 



[0041] In this example k= 1 , that is, the matrix S is not really block-Toeplrtz, but rather, it has an ordinary Toeplitz 
structure. The matrix S has a band structure with v= 2. The exact Cholesky factor R, to four decimal places is: 



35 



2.0000 1.0000 0.0000 
0.0000 1.7321 1.1547 
0.0000 0.0000 1.6330 



40 



4S 



[0042] As can be seen, R also has band-structure with v= 2 and the elements down the diagonals can be considered 
to be approximately equal. This approximate equality is much more pronounced for larger matrices. Equation (8) pro- 
vides for the case that only elements r n and r 12 should be computed, and the rest is copied. The approximating algo- 
rithm now starts by computing r n and then r 12 . The element r 13 should be "copied" and is set to zero because the 
element that would be approximately equal to it, r m12 > does not exist. This is correct because r 13 is known to be zero 
due to the band structure of R. The algorithm then proceeds to copy elements r 23 and from their respective 
approximations r 1v r^and Thus, R according to equation (8) is: 



60 



2.0000 1.0000 0.0000 
0.0000 2.0000 1.0000 
0.0000 0.0000 2.0000 



55 



[0043] The calculation of A< 8 > requires one square root operation and one division. Using the known approximation 
technique, we would have also had to calculate element r 22 : 
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2.0000 1.0000 0.0000 
0.0000 1.7321 1.0000 
0.0000 0.0000 1.7321 



requiring two square root operations and two divisions. 
10 [0044] Clearly, this is a better approximation than fl( 8 ). But considering that computing the rest of the second row 
does not involve the costly square root operation and division, it would be advantageous to also compute r 23 (but not 
r^j). The matrix oriented approach known to those skilled in the art can not express this. The rule for this would be: 



15 



shall we compute ? a is / £ Wand j £ (v + M)*? 



(9) 



20 



25 



30 



[0045] This rule computes all non-zero elements of the first /r/rows. For our example, with / = 2 the factor matrix 
becomes; 



2.0000 1.0000 0.0000 
0.0000 1.7321 1.1547 
0.0000 0.0000 1.7321 



with only two square roots and two divisions. This is a better approximation than FH 6 \ with the same amount of square 
roots and divisions. 

[0046] As will be appreciated by those skilled in the art various modifications may be made to the illustrative embod- 
iment without departing from the scope of the present invention. In particular, multi-user detection in a W-CDMA system 
can be also effected. In this case data detection from wanted radio signals in the presence of unwanted radio signals 
is expressed according to equation (10): 



35 



£<fec = ctec ( R wy) 



(10) 



40 



[0047] In equation (10), where R w is the cross-correlation matrix of the system (not a Cholesky factor), and dec () 
is a function which determines a part of the complex plane within which the signals fall. The cross-correlation matrix 
R w , is a Hermitian, positive semi-definite, block-Toeplitz, band matrix. Solving equation (10) efficiently amounts again 
to computing the Cholesky factor of R w . As a result of the special structure of R Wt as with the correlation matrix A H 
A , the desired Cholesky factor R has the same band structure and is approximately block-Toeplitz. 



45 



50 



55 



Claims 



A radio communications receiver which operates to detect radio signals and to recover data representative of the 
radio signals in the presence of contemporaneously detected interfering signals, said radio communications re- 
ceiver comprising; 

means to detect said radio signals (6, 8) and to generate digital base band signals representative of said radio 
signals, 

means to form a correlation matrix (12) from said base band signals, and 

a data processor (16) which operates to generate a factor (R) of said correlation matrix (S), and to recover 
said data (d) from said factor matrix (R), wherein said data processor (16) operates to generate said factor 
matrix (R) by; 

calculating first elements of the factor (R) from the correlation matrix (S) using a factorisation algorithm, in 
accordance with a pre-determined structure of the factor matrix (R) ; and 
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forming second elements of the matrix (R) by selectively copying first elements in accordance with said pre- 
determined structure. 

2. A radio communications receiver as claimed in Claim 1 , wherein said pre-determined structure of the factor (R), 
s is determined in accordance with a band structure of the factor matrix (R). 

3. A radio communications receiver as claimed in Claim 1 or 2, wherein the first elements are contained in at least 
one row of said factor (R), and said second elements are contained in at least one second row of said factor (R). 

10 4. A radio communications receiver as claimed in any preceding Claim, wherein said first and second elements are 
present in the same row. 

5. A radio communications receiver as claimed in Claim 4, wherein the data processor operates to generate said 
factor (R) in accordance with the following steps; 

15 

for each row of said matrix factor (R) (for / in 1 to n); 
determining, from the predetermined structure; 

whether the elements of the row (for j in i to n) of the matrix (R) should be calculated using said factorisation 
algorithm, and calculating said element using said factorisation algorithm and corresponding elements from 
20 the correlation matrix (S); or 

whether the elements of the row (for j in / to n) of the matrix (R) is one of the second elements and can be 
copied from said first elements, and copying said elements from said first elements. 

6. A radio communications receiver as claimed in any preceding Claim, wherein the rows are columns of the factor 
25 (R) and the columns are the rows of the matrix (R). 

7. A radio communications receiver as claimed in any preceding Claim, wherein the factor (R) is upper or lower 
triangular. 

30 8. A radio communications receiver as claimed in any preceding Claim, wherein said radio signals and said interfering 
signals are generated in accordance with a code division multiple access scheme. 

9. A radio communications receiver as claimed in any preceding Claim, wherein said factorisation algorithm is the 
Cholesky or Block-Schur algorithm. 

35 

10. A method of detecting a radio signal and recovering data representative of said radio signal in the presence of 
interfering signals, said method comprising the steps of; 

detecting said radio signals and generating digital base band signals representative of said radio signals, 
40 - generating a correlation matrix (S) from said base band signals, 

generating a matrix factor (R) of said correlation matrix, and 

recovering said data from said factor (R), wherein said factor (R) is generated in accordance with the following 
operations; 

calculating first elements of the factor (R) from the correlation matrix (S) using a factorisation algorithm, in 
45 accordance with a pre-determined structure of the factor (R) ; and 

forming second elements of the matrix (R) by selectively copying elements from said first rows in accordance 
with said pre-determined structure. 

11 . A method as claimed in Claim 1 0, wherein said pre-determined structure of the factor (R), is determined in accord- 
so ance with a band structure of the factor matrix (R). 

12. A method as claimed in Claim 10 or 11, wherein said first elements are contained in at least one first row of the 
factor (R), and said second elements are contained in at least one second row of the matrix factor (R). 

55 13. A method as claimed in Claims 10, 11 or 12, wherein said first and second elements are present in the same row. 

14. A method as claimed in Claim 13, wherein said factor (R) is generated in accordance with the following steps; 
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- for each row of said factor (R) (for i in 1 to n); 
determining, from the predetermined structure; 

- whether the elements of the row (for j in i to n) of the matrix (R) should be calculated using said factorisation 
algorithm, and calculating said element using said factorisation algorithm and elements from the correlation 

s matrix (S) ; or 

- whether the elements of the row (for j in i to n) of the matrix (R) is one of said second elements and can be 
copied from said first elements, and copying said elements from said first elements. 

15. A method as claimed in any of Claim 10 to 14, wherein the rows are columns of the factor (R) and the columns 
10 are the rows of the matrix (R). 

1 6. A method as claimed in any of Claims 1 0 to 1 5, wherein the factor (R) is upper or lower triangular. 

17. A method as claimed in any of Claims 1 0 to 1 6, wherein said radio signals and said interfering signals are generated 
is in accordance with a code division multiple access scheme. 

18. A method as claimed in any of Claims 10 to 17, wherein said factorisation algorithm is a Cholesky algorithm or a 
Block-Schur algorithm. 

20 19. A method of generating at least one factor (R) of a matrix (S), said factor (R) being upper or lower triangular in 
form, said method comprising the steps of; 

calculating first elements of the factor (R) from the matrix (S) using a factorisation algorithm, in accordance 
with a pre-determined structure; and 
2$ - forming second elements of the matrix (R) by selectively copying elements from said first elements in accord- 
ance with said pre-determined structure. 

20. A method as claimed in Claim 15, wherein said first elements are contained in at least one first row of the matrix 
factor (R), and said second elements are contained in at least one second row of the matrix factor (R). 

30 

21. A method as claimed in Claim 20, wherein said pre-determined structure of the factor (R), identifies said at least 
one first row of the factor (R) to be calculated in accordance with the factorisation algorithm, and said second 
elements of the factor matrix (R) in accordance with a band structure. 

35 22. A method as claimed in any of Claims 1 9 to 21 , and further including the step of; 

- for each row of said factor (R) (for / in 1 to n)\ 
determining, from the pre-determined structure, 

- whether the elements of the row (for j in / to n) of the matrix (R) should be calculated using said factorisation 
40 algorithm, and calculating said element using said factorisation algorithm and elements from the matrix S); or 

- whether the elements of the row (for j in i to n) of the matrix (R) can be copied from said first elements, and 
copying said first elements. 

23. A method as claimed in any of claims 19 to 22, wherein the rows are columns of the factor (R) and the columns 
45 are the rows of the matrix (R). 

24. A method as claimed in any of claims 1 9 to 23, wherein said radio signals and said interfering signals are generated 
in accordance with a code division multiple access scheme. 

50 25. A data processor which operates to generate at least one factor (R) of a matrix (S), according to the method claimed 
in any of claims 1 9 to 24. 

26. A radio communications receiver as herein before described with reference to the accompanying drawings. 

55 
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